// hooks 封装逻辑，提供响应式数据。
import { useIntersectionObserver } from '@vueuse/core'
import { ref } from 'vue'
// 数据懒加载函数
export const lazyLoad = (api) => {
    // 需要
    // 1. 被观察的对象
    // 2. 不同的API函数
    const list = ref([])
    const target = ref(null)
    const { stop } = useIntersectionObserver(
        target,
        ([{ isIntersecting }]) => {
            if (isIntersecting) {
                stop()
                // 调用API获取数据
                api().then(res => {
                    list.value = res.result
                    console.log('返回请求', res);
                })
            }
        },
        {
            threshold: 0
        }
    )
    // 返回--->数据（dom,后台数据）
    return { list, target }
}